﻿Proiect la cursul de Programare Bazată pe Reguli Informatică III, semestrul 2, martie 2014 Sentimentele pot influența evoluția unei societăți (a sentiment-driven society) Imaginați o societate populată de oameni care sunt influențați de sentimente Un eveniment poate trezi un sentiment într-un individ, iar existența unui sentiment într-un individ îl poate determina pe acesta la acțiuni care să schimbe lumea reală Un sentiment poate fi pozitiv ori negativ și poate fi exprimat pe o scară de la -3 la +3 Valoarea 0 semnifică lipsa unui sentiment, adică o stare neutră Starea de „fericire“ a unui individ depinde de balansul dintre plus și minus și ea cumulează mai multe stări afective, ca urmare este o caracteristică măsurabilă Fiecare om are personalitatea sa O trăsătură a personalității măsoară gradul de sensibilitate al individului la evenimente, adică măsura în care un eveniment pozitiv ori negativ afectează starea individului De aceea, același eveniment poate provoca stări afective 1 diferite în oameni diferiți Dorim să modelăm o societate (comunitate de indivizi) în care se întâmplă evenimente ce vor afecta gradul de fericire al indivizilor Mai mult încă, anumite stări emoționale îi determină pe oameni să acționeze, ceea ce provoacă alte stări în alți indivizi ș a m d Jucați-vă cu o societate în care „clonați“ un număr de personalități în indivizi separați și în care amorsați un proces evenimențial (provocați unul sau mai multe evenimente primordiale) Observați evoluția în timp a acelei comunități Jucați-vă la parametri până obțineți o societate „perfectă“, adică una care manifestă maximumul posibil al stării globale de fericire Distribuția personalităților în comunitate trebuie să fie uniformă (același număr de melancolici, colerici, sanguini, flegmatici) Descrieţi un scenariu în care personajele iau parte la evenimente Voi controlați dispunerea în timp a avenimentelor (simulaţi întâmplarea) Trăsăturile de caracter şi de personalitate se descriu ca reguli în care intervin evenimente, obiecte, agenţi şi sentimente Descrieţi o listă de personaje ca având anumite trăsături de caracter şi de personalitate Amorsaţi procesul de inferenţă CLIPS Aplicarea în timp a secvenţei de evenimente produce la anumite momente alte evenimente, după cum unele evenimente apar datorită „întâmplării” Vrem să daţi un raport (log) asupra evenimetelor care apar şi trăirilor (în timp) ale personajelor Utilizaţi FUZZY-CLIPS pentru proiectarea regulilor Exemplu de scenariu: conflictul ucraineano-rus din Crimeea 1 Modelarea sentimentelor şi a manifestărilor raţionale Sunt caracterizate de o durată (interval) în care se manifestă Sentimentele au roluri: agent, cauză, receptor (obiect) 1 Ipoteza noastră este una simplificatoare În realitate oamenii sunt influențabili De exemplu, adesea ei preferă să se alăture unui spirit colectiv, să “împărtășească” opiniile legitime și să le exprime, decât să fie marginalizați – v Spirala tăcerii, Elisabeth Noelle-Neuman, 1947 Scara de valori: intensitate Unele sentimente pot fi controlate (atributul VOLIT cu valorile true, false) Plasarea unor afecte în sfera sentimentelor este fuzzy O măsură a ceea ce poate fi luat ca sentiment este valoarea false a VOLITivului: cu cât un afect este mai puţin controlabil, cu atât mai mult el poate fi considerat un sentiment; cu cât el este mai controlabil – cu atât el poate fi considerat o manifestare raţională mai mult decât un sentiment Sentimentele se pot manifesta făţiş ori ascunde de către subiectul care le experimentează (trăieşte) Unele sentimente pot fi simulate de anumiţi agenţi Simularea poate induce în eroare ori nu un alt agent Pe o anumită axă nu pot exista simultan mai mult decât un sentiment cu aceleaşi roluri Valabil pentru unele axe: sentimentele din jurul valorii de zero pot fi de lungă durată, spre deosebire de cele extreme care se manifestă scurt în timp 2 1 Axele sentimentelor Axa interesului - apatie (AG, CA, OB, VOLIT: true) - interes major - dezinteres total Axa recunoştinţei - gratitudine (AG, CA, OB: agent, VOLIT: true) - ingratitudine (AG, CA, OB: agent, VOLIT: true) Axa amuzamentului/hilarităţii - seriozitate - amuzament (manifestare printr-o grimas ă : zâmbet, râs) Amuzamentul este receptiv pe când ironia este dubitativă Axa milei - cruzime - mil ă Axa afecţiunii - afec ţ iune ( like) (AG, CA?, OB: ag, ob, id, VOLIT: false) - simpatie(AG, CA?, OB: ag, ob, id, VOLIT: false) - dragoste(AG, OB: ag, VOLIT: false) - dezagreere ( dislike ) (AG, CA, OB) - antipatie(AG, CA, OB: ag, VOLIT: false) - ur ă (AG, CA, OB: ag, idee, ob, VOLIT: false) - repulsie(AG, CA, OB, VOLIT: false) dezagreere afecţiune mare negativ ură mare pozitiv repulsie antipatie 0 simpatie afecţiune dragoste indiferenţă Axa curajului-fricii - incon ş tien ţă (curaj peste m ă sur ă )(AG, CA, OB: ob, ag, ev, VOLIT: false) - team ă (AG, CA, OB: agent, ob, ev, sit, VOLIT: false) - fric ă (AG, CA, OB: agent, ob, ev, sit, VOLIT: false) - fobie (AG, CA, OB, VOLIT:false) frică curaj mare negativ fobi e frică teamă 0 indiferenţă inconştienţă mare pozitiv Axa interesului zona lipsei de cunoaştere starea de dezinteres mare negativ apatie dezinteres total starea de interes mare pozitiv interes major necunoaştere gelozie (AG, CA?, OB, VOLIT: false) Axa geloziei zona superficialităţii starea de rău mare negativ gel ozie 0 Axa invidiei - apreciere (AG, CA:ob, ev, OB:ag, VOLIT:false, true) - invidie (AG, CA:ob, ev, OB:ag, VOLIT:false) starea de rău mare negativ inv idie zona superficialităţii 0 apreciere mare pozitiv Axa calmului (liniştei, echilibrului emoţional) - calm (AG, CA(opt), VOLIT: false, true) - sup ă rare (AG, CA, OB: agent, ob, VOLIT: false, true) - furie (AG, CA, OB: agent, ob, ev, sit, VOLIT: false) starea de agitaţie Axa criticii * aprobare - entuziasm (AG, CA: ob, ag, ev, VOLIT: false) * dezaprobare - indignare (AG, CA: ob, ag, ev, VOLIT: false) zona de dezaprobare mare negativ in dignare zona lipsei de interes 0 zona de aprobare entuziasm mare pozitiv dezinteres Axa ruşinii - mândrie (AG, CA: ev, VOLIT: false, true) - nep ă sare (AG, CA: ev, VOLIT: false) - remu ş care (AG, CA: ev, VOLIT: false) - regret (AG, CA: ev, VOLIT: false, true) - ru ş ine (AG, CA: ev, VOLIT: false, true) Implicarea afectivă pe această scară presupune o legătură între AG şi agentul evenimentului din CA mare negativ ruş ine regret remuşcare nepăsare Cazul special al fericirii Fericirea reprezintă cumulul trăirilor individului Ea este o rezultantă a mai multor trăiri combinate și are și ea grade de intensitate: - extaz - fericire - bucurie - melancolie - triste ţe - nefericire - devastat zona superficialităţii starea de rău starea de bine mare negativ nefe ricire tristeţe melancolie bucurie indiferenţă mare pozitiv fericire Interacţiuni între sentimente Sentimentele de pe axe diferinte pot interacţiona chiar şi în situaţia în care au aceleaşi roluri Cazuistică Ion, Maria, Ghiţă, Lenuţa 1 Ion îşi parcheză maşina (Toyota), Maria, neglijentă, îl loveşte cu maşina ei (Hummer), Ion din calm devine furios, au loc altercaţii din partea lui Ion, Maria are de gând sa-şi ceară scuze dar devine indignată şi cearta e gata ^ se citeşte „urmează în timp” Ion Maria Toyota: maşina lui Ion Hummer: maşina Mariei lovi (AG, REC) constata-dauna (AG, REC) adresa-injurie(AG, REC) planifica (AG, OB: ev) adresa-scuze (AG, REC) certa (AG1, REC, CA) calm (Ion); calm (Maria); se1: simpatie (Ion, nil, Toyota) - Ion ţine la maşina lui ev1: loveşte (Hummer, Toyota) ^ indignare(Ion, ev1) ^ regret(Maria, ev1) ^ ev4: planifică(Maria, ev3: adresează-scuze(Maria, Ion)) ^ ev2: constată-dauna(Ion, Toyota) ^ furie(Ion, se1&ev2) ^ ev5: adresează- injurie(Ion, Maria) ^ indignare(Maria, ev5) ^ ev6: ceartă(Ion, Maria, ev1) ^ ev7: ceartă (Maria, Ion, ev5) Configurarea personalităţii unui agent (AG) Personalitatea unui agent: poate fi modificată în timp prin interacţiunea cu mediul (societatea) - temperamentul (constant): coleric: extrovertit/puternic/agresiv/insensibil/energic, oscilează rapid între un sentiment şi opusul lui melancolic: introvertit/îngrijorat și emotiv/creativ/conștiincios și perfecționist/capricios, gânditor și sensibil, oscilează rapid între un sentiment şi opusul lui sangvin: extrovertit/sociabil și deschis/neatent/împrăștiat și neorganizat/voios, vesel și fără griji, echilibrat flegmatic: introvertit/calm, comod și nepăsător/cu tact și diplomație/politicos, amabil, liniștit/flexibil, echilibrat - caracterul (se formeaz ă ) - egoist (egocentrist) - zgârcenie - altruist - generozitate - mândrie, arogan ţ a - timiditate - curaj - sensibilitate - delicate ţ e - ironie Proiectarea unor reguli de inferenţă în zona afectivă şi a comportamentului social Tipul coleric if calm(AG) şi pe această stare apare un eveniment (ev) neplăcut pentru AG then furie(AG, ev) Tipul flegmatic if calm(AG) şi pe această stare apare un eveniment (ev) neplăcut pentru AG then supărare(AG, ev) Tipul melancolic if calm(AG) şi pe această stare apare un eveniment (ev) neplăcut pentru AG then supărare(AG, ev, INTENS=mare) Tipul sangvin if calm(AG) şi pe această stare apare un eveniment (ev) neplăcut pentru AG then calm(AG, ev) Timpul trebuie adăugat? – Categoric, Da Reac ț ion ă m diferit în func ț ie de starea de spirit în care suntem prin ș i într-un anumit moment, contextul în care ne aflăm, alți factori perturbatori, zgomot de fond etc - afec ţ iune ( like) (AG, CA?, OB: ag, ob, id, VOLIT: false) - simpatie (AG, CA?, OB: ag, ob, id, VOLIT: false) - dragoste (AG, OB: ag, VOLIT: false) - dezagreere ( dislike ) (AG, CA, OB) if indiferenţă (AG, OB) ∨ simpatie(AG, OB) ∨ dragoste(AG, OB) & apare un eveniment în care este implicat AG ca REC, eveniment cauzat de un alt agent AG1 & evenimentul produce un efect negatov asupra AG De folosit în reguli: - antipatie (AG, CA, OB: ag, VOLIT: false) - ur ă (AG, CA, OB: ag, idee, ob, VOLIT: false) - repulsie (AG, CA, OB, VOLIT: false) Despre fuzzy-CLIPS a se vedea http://thor info uaic ro/~dcristea/cursuri/SE/fzdocs pdf Exercițiu la curs Mai jos este un exercițiu de reprezentare a acțiunilor pentru episodul „anexarea Crimeei” Mai întâi sunt propuse o seamă de template-uri de acțiuni elementare cu rolurile/atributele lor, apoi o seamă de personaje și mai jos o secvență de acțiuni În această reprezentare nu apar încă înrâuriri ale acțiunilor datorate trăirilor afective Procesele de raționament sunt excluse din simulare (așteptăm propuneri ale dumneavoastră în privința asta, pentru că în dezvoltările de pe un câmp de operațiuni militare/politice primordiale sunt actele volitive și doar în al doilea rând – cele datorate afectivității) Acțiuni: - verbal threat(ACT), gestual threat(ACT): un agent(PERSON) amenin ță un target(PERSON); - treason(ACT): un agent(PERSON), tr ă deaz ă o country(LOCATION) printr-un act(ACT); - shot(ACT): un agent(PERSON) împu ș c ă o victim(PERSON); - manifestation(ACT): un agent(PERSON) manifesteaz ă pentru un goal(OBJECTIVE) sau împotriva lui, conform valorii de adevăr a lui pro(BOOL); - troops movement(ACT): rezultat al lui order(DECISION) dat de un agent(PERSON) o army(PERSON-GROUP) intră într-o anumită zone(LOCATION-AREA) cu un anumit goal(OBJECTIVE); - fight(ACT): rezultat al lui order-offensive(DECISION) dat de un agent- offensive(PERSON) și a unui order-deffensive(DECISION) dat de un agent-defensive (PERSON) o army-offensive(PERSON-GROUP) luptă împotriva unei army- defensive(PERSON-GROUP) într-o location(LOCATION) cu un anumit rezult(BOOL); dacă result=TRUE => cucerire; dacă result=FALSE => retragere; - invasion(ACT): rezultat al lui order(DECISION) dat de un agent(PERSON) o army(PERSON-GROUP) invadează o zone(LOCATION-AREA) cu sau fără luptă, în funcție de valoarea de adevăr a lui fight(BOOL); - issue-order(VOLITIVE): un agent(PERSON) dă ordinul object(ACT) lui addressee(PERSON) cu un goal(VOLITIVE); Persoane: Putin: [function=president, citizenship=Russia, nation=Russia] Yanoukovich: [function=ex-president, citizenship=Ukraine, nation=Ukraine] Turchynov: [function=president, citizenship=Ukraine, nation=Ukraine] Berezovsky: [function=navy-commander, citizenship=Ukraine, nation=Ukraine] Hayduk: [function=navy-commander, citizenship=Ukraine, nation=Ukraine] Chirkov: [function=navy-commander, citizenship=Russia, nation=Russia] Crimean 1: [function=null, citizenship=Ukraine, nation=Russia, location: Crimea] Crimean 2: [function=null, citizenship=Ukraine, nation=Russia, location: Crimea] Crimean 3: [function=null, citizenship=Ukraine, nation=Russia, location: Crimea] Crimean 501: [function=null, citizenship=Ukraine, nation=Ukraine, location: Crimea] Crimean 502: [function=null, citizenship=Ukraine, nation=Ukraine, location: Crimea] Crimean 503: [function=null, citizenship=Ukraine, nation=Ukraine, location: Crimea] Russian 1: [function=Senator, citizenship=Russia, nation=Russia, location: Moskow] Russian 2: [function=Senator, citizenship=Russia, nation=Russia, location: Moskow] Russian 3: [function=Senator, citizenship=Russia, nation=Russia, location: Moskow] navy 1: [function=marine, citizenship=Russia, nation=Russia, location:Crimea] navy 2: [function=marine, citizenship=Russia, nation=Russia, location:Crimea] navy 3: [function=marine, citizenship=Russia, nation=Russia, location:Crimea] Acțiuni Day1: decision1(issue-order): [agent=Putin, object=invade Crimea, addressee=Chirkov, goal: anex Crimea] Day2: t m1(troops movement):[order=decision1, agent=Chirkov, army={navy 1, navy 2, navy 3, }, zone=Crimea, goal= invade Crimea] Day3: invasion1(invasion): [order=decision1, agent=Chirkov, army={navy 1, navy 2, navy 3, }, zone=Crimea, fight=FALSE] Day4: decision2(decision): [agent= Turchynov, object=defend Crimea, addresse: Berezovsky, goal: keep Crimea] Day5: treason1(treason): [agent=Berezovsky, country=Ukraine, act=surrender troops] Day6: decision3(decision): [agent=Turchynov, object=dismiss traitor, addresse: Berezovsky, goal: keep Crimea] Day7: decision4(decision): [agent=Turchynov, object=name navy commander, addresse:Hayduk, goal: keep Crimea] Day8: decision5(decision): [agent=Turchynov, object=opose invasion, addresse:Hayduk, goal: keep Crimea] Day9: Următoarele acte sunt rezultate ale unor trăiri afective: - decision1: Putin hot ă r ăș te anexarea Crimeei ca un act de mare patriotism; - decision2: din sentimente patriotice, Turchynov hot ă râ ș te men ț inerea Crimeei cu orice chip, ca urmare îi dă ordin lui Berezovsky să apere Crimea; - treason1: Berezovsky nu îndepline ș te ordinul pentru ca el consider ă ca acesta va duce la vărsări inutile de sânge fraticid; - decision3, decision4, decision5: Turchynov hotărăște schimbarea comandantului marinei Marii Negre și menținerea Crimeei cu orice chip; În cazul următoarelor acte, trăirile afective nu au dus la încălcarea ordinelor: - t m1, invasion1: mi ș carea de trupe în vederea invaziei ș i invazia ca atare sunt rezultatele unor ordine primite de la superiori 